<template>
    <div class="swiper-container" id="floor1Swiper" ref="cur">
        <div class="swiper-wrapper">
            <div class="swiper-slide" v-for="(carousel, index) in list" :key="index">
                <img :src="carousel.imgUrl" />
            </div>
        </div>
        <!-- 如果需要分页器 -->
        <div class="swiper-pagination"></div>

        <!-- 如果需要导航按钮 -->
        <div class="swiper-button-prev"></div>
        <div class="swiper-button-next"></div>
    </div>
</template>

<script>
import Swiper from "swiper";
export default {
    name: "Carousel",
    props: ['list'],
    watch: {
        list: {
            // 立即监听：不管你数据有没有变化，上来就立即监听一次
            // 为什么watch监听不到list:因为这个数据从来都没有发生变化（数据是父亲给的，给的时候就是一个对象，对象里面由数据）
            immediate: true,
            handler() {
                // 只能监听到数据已经有了，但是v-for动态渲染结构我们还没有办法确定，因此还是需要用nextTick
                this.$nextTick(() => {
                    var mySwiper = new Swiper(
                        this.$refs.cur,
                        {
                            loop: true,
                            pagination: {
                                el: ".swiper-pagination",
                                clickable: true,
                            },
                            navigation: {
                                nextEl: ".swiper-button-next",
                                prevEl: ".swiper-button-prev",
                            },
                        }
                    );
                })
            }
        }
    }
};
</script>
<style scoped>
</style>>
